import React, { Component } from 'react';
import Header from './components/Header';
import Footer from './components/Footer';
import List from './components/List';
import './App.css';

export default class App extends Component {
  state = {
    todos: [
      {
        id: 1,
        text: '吃饭',
        done: true
      },
      {
        id: 2,
        text: '睡觉',
        done: true
      },
      {
        id: 3,
        text: '打豆豆',
        done: false
      }
    ]
  }

  // 添加任务
  addTodo = (todoObj) => {
    const todos = [...this.state.todos];
    todos.unshift(todoObj);
    this.setState({
      todos
    });
  }

  // 更新任务状态
  updateTodo = (id, done) => {
    const todos = [...this.state.todos];
    const newTodos = todos.map(item => {
      if (item.id === id) {
        return { ...item, done }
      } else {
        return item;
      }
    })
    this.setState({ todos: newTodos })
  }


  render () {
    return (
      <div className="todo-warp">
        <Header addTodo={this.addTodo} />
        <List todos={this.state.todos} updateTodo={this.updateTodo} />
        <Footer />
      </div>
    )
  }
}